## گزارش کار شماره 6 آزمایشگاه مدار منطقی

سروين نامى 9931103 آبتين زندى 9931071

آزمایش شماره 6 بخش اول:

در این آزمایش باید مدار یک مقایسه کننده سه بیتی را پیاده سازی کنیم که عدد A را با عدد B مقایسه کند و سپس با چک کردن مقادیر D و D و D می توانیم متوجه شویم آیا این دو عدد مساوی هستند یا یکی از دیگری بزرگ تر است

مطابق شکل زیر کد را می نویسیم:

## 3 bit comparator verilog code:

```
module ThreeCopratitorModule(
   input A0,
   input A1,
  input A2,
  input B0,
  input B1,
  input B2,
  output LT,
   output GRT,
   output EQ
  );
//LOGICAL CALCULATION 3Bit comprator
 assign LT = (B2 & (~A2)) || ((~(A2^B2)) & (B1 & (~A1))) || ((~(A2^B2)) & (~(A1^B1)) & (B0 & (~A0)));
 assign EQ = (\sim (A0 ^ B0)) & (\sim (A1^B1)) & (\sim (A2^B2));
endmodule
```

سپس TestBench ها را می نویسیم و شبیه سازی را اجرا می کنیم به علت زیاد بودن حالات در دو تست بنج این آزمایش را بررسی می کنیم:

# 3 bit comparator TestBench 1:

```
// Wait 100 ns for global reset to finish
#100;
#50 A0=0; A1=0; A2=0; B0=0; B1=0; B2=0;
#50 A0=0; A1=0; A2=0; B0=0; B1=0; B2=1;
#50 A0=0; A1=0; A2=0; B0=0; B1=1; B2=0;
#50 A0=0; A1=0; A2=0; B0=0; B1=1; B2=1;
#50 A0=0; A1=0; A2=0; B0=1; B1=0; B2=0;
#50 A0=0; A1=0; A2=0; B0=1; B1=0; B2=1;
#50 A0=0; A1=0; A2=0; B0=1; B1=1; B2=0;
#50 A0=0; A1=0; A2=0; B0=1; B1=1; B2=1;
#50 A0=1; A1=1; A2=1; B0=0; B1=0; B2=0;
#50 A0=1; A1=1; A2=1; B0=0; B1=0; B2=1;
#50 A0=1; A1=1; A2=1; B0=0; B1=1; B2=0;
#50 A0=1; A1=1; A2=1; B0=0; B1=1; B2=1;
#50 A0=1; A1=1; A2=1; B0=1; B1=0; B2=0;
#50 A0=1; A1=1; A2=1; B0=1; B1=0; B2=1;
#50 A0=1; A1=1; A2=1; B0=1; B1=1; B2=0;
#50 A0=1; A1=1; A2=1; B0=1; B1=1; B2=1;
#100;
$finish;
// Add stimulus here
```

#### 3 bit comparator TestBench 1 Timeline:



# 3 bit comparator TestBench 2:

```
// Wait 100 ns for global reset to finish
#100;
#50 A0=0; A1=0; A2=0; B0=0; B1=0; B2=0;
#50 A0=1; A1=1; A2=0; B0=0; B1=0; B2=1;
#50 A0=1; A1=0; A2=1; B0=1; B1=1; B2=0;
#50 A0=0; A1=1; A2=1; B0=0; B1=1; B2=1;
#50 A0=1; A1=0; A2=0; B0=1; B1=1; B2=0;
#50 A0=1; A1=1; A2=0; B0=1; B1=0; B2=1;
#50 A0=0; A1=1; A2=0; B0=1; B1=1; B2=0;
#50 A0=0; A1=1; A2=0; B0=1; B1=1; B2=1;
#100;
$finish;
```

# 3 bit comparator TestBench 2 Timeline:



3.2)8 bit comparator using 2 3 bit comparators

```
13 //
14 // Dependencies:
 15 //
 16 // Revision:
17 // Revision 0.01 - File Created
 18 // Additional Comments:
 19 //
 21
    module comparator_3_bit(
 22
        input A0,
 23
        input Al,
 24
        input A2,
 25
        input BO,
 26
        input Bl,
 27
        input B2,
 28
        output LT,
        output GRT,
 29
       output EQ
 30
 31
      32
      assign GRT = (A2 & (~B2)) | ((~(A2^B2)) & (A1 & (~B1)) | ((~(A2^B2)) & (~(A1^B1)) & (A0 & (~B0)));
assign EQ = (~(A0 ^ B0)) & (~(A1^B1)) & (~(A2^B2));
 33
 34
 35
 36 endmodule
37
31
        input bl,
32
        input b2,
33
        input b3,
34
        input b4,
35
        input b5,
36
        input b6,
       input b7,
37
        output LT,
38
        output GRT,
39
        output EQ
40
       );
41
42 wire ltl;
43 wire lt2;
44 wire grtl;
 45 wire grt2;
 46 wire eql;
47 wire eq2;
48 comparator 3 bit cl(a5,a6,a7,b5,b6,b7,ltl,grtl,eql);
49 comparator_3_bit c2(a2,a3,a4,b2,b3,b4,lt2,grt2,eq2);
50
assign LT = ltl|(lt2&eq1)|(eq1&eq2&(((~a1)&b1))|((~(a1^b1))&(~a0)&b0)));

52 assign GRT = grtl|(grt2&eq1)|(a1&(~b1)&eq1&eq2)|(a0&(~b0)&eq1&eq2&(~(a1^b1)));
53 assign EQ = eql&eq2&(~(al^bl))&(~(a0^b0));
54 endmodule
55
```

```
0;
    81
                        0;
    82
    83
                         0;
                         0:
     84
                         0;
     85
                         0;
     86
                         0;
     87
                         0;
     88
                         0;
    89
                         0;
     90
     91
                     ait 100 ns for global reset to finish
    92
     93
    94 a0 = 0;a1 = 0;a2 = 0;a3 = 0;a4 = 1;a5 = 1;a6 = 0;a7 = 0;b0 = 0;b1 = 0;b2 = 0;b3 = 0;b4 = 1;b5 = 1;b6 = 0;b7 = 0;
                       a0 = 0;a1 = 0;a2 = 0;a3 = 0;a4 = 1;a5 = 0;a6 = 1;a7 = 0;b0 = 0;b1 = 0;b2 = 0;b3 = 1;b4 = 0;b5 = 0;b6 = 0;b7 = 1;a0 = 0;a1 = 0;a2 = 0;a3 = 0;a4 = 1;a5 = 1;a6 = 1;a7 = 1;b0 = 0;b1 = 0;b2 = 0;b3 = 0;b4 = 0;b5 = 1;b6 = 0;b7 = 1;a6 = 1;a7 = 1;b0 = 0;b1 = 0;b2 = 0;b3 = 0;b4 = 0;b5 = 1;b6 = 0;b7 = 1;a6 = 1;a7 = 1;b0 = 0;b1 = 0;b2 = 0;b3 = 0;b4 = 0;b5 = 1;b6 = 0;b7 = 1;a6 = 1;a7 = 1;b0 = 0;b1 = 0;b2 = 0;b3 = 0;b4 = 0;b5 = 1;b6 = 0;b7 = 1;a6 = 1;a7 = 1;b0 = 0;b1 = 0;b2 = 0;b3 = 0;b4 = 0;b5 = 1;b6 = 0;b7 = 1;a6 = 0;b7 = 1;a6 = 0;b7 = 0;b1 = 0;b2 = 0;b3 = 0;b4 = 0;b5 = 1;b6 = 0;b7 = 1;a7 = 0;b7 = 0;b1 = 0;b2 = 0;b3 = 0;b4 = 0;b5 = 1;b6 = 0;b7 = 1;a7 = 0;b7 = 0;b1 = 0;b2 = 0;b3 = 0;b4 = 0;b5 = 0;b6 = 0;b7 = 1;a7 = 0;b7 = 0;b1 = 0;b2 = 0;b3 = 0;b4 = 0;b5 = 0;b6 = 0;b7 = 1;a7 = 0;b7 = 0;b1 = 0;b2 = 0;b3 = 0;b4 = 0;b5 = 0;b6 = 0;b7 = 1;a7 = 0;b8 = 0;b8
     95
     96
     97
                        a0 = 0;a1 = 0;a2 = 0;a3 = 1;a4 = 1;a5 = 0;a6 = 0;a7 = 0;b0 = 0;b1 = 0;b2 = 0;b3 = 1;b4 = 1;b5 = 0;b6 = 0;b7 = 0;
    98
    99
100 .dd stimulus here
101
102
103
104
```

